package com.fengye.algorithms.leecode;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

/**
 * @Author fengye
 * @Date 2023/4/8 9:51
 **/
public class ThreeSum15 {
    public List<List<Integer>> threeSum(int[] nums) {
        // 先排序
        Arrays.sort(nums);
        List<List<Integer>> res = new ArrayList<>();
        for(int i=0;i<nums.length;i++) {
            if(i>0&&nums[i] == nums[i-1]) {
                continue;
            }
            // 因为目标=0，把三数问题改成2数问题
            int target = -nums[i];
            int t = nums.length-1;
            for(int j=i+1;j<nums.length;j++) {
                if(j>i+1&&nums[j] == nums[j-1]) {
                    continue;
                }
                while (j < t && nums[j]+nums[t] > target) {
                    t--;
                }
                if(j >= t) {
                    break;
                }
                if(nums[j]+nums[t] == target) {
                    List<Integer> list = new ArrayList<>();
                    list.add(nums[i]);
                    list.add(nums[j]);
                    list.add(nums[t]);
                    res.add(list);
                }
            }
        }
        return res;
    }
}
